<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl">
    <script>
        function moveSelected(src,target){
            $("."+target).append($("."+src+" > option:selected"))
        }
        function moveAll(src,target){
            $("."+target).append($("."+src+" > option"))
        }

        $(function () {
            //表单验证
            $('#editForm').bootstrapValidator({
                feedbackIcons: {
                    valid: 'glyphicon glyphicon-ok',
                    invalid: 'glyphicon glyphicon-remove',
                    validating: 'glyphicon glyphicon-refresh'
                },
                fields: { //规则
                <#if !employee??>
                    name:{
                        validators:{ //可以配置多个规则
                            notEmpty:{
                                message:'用户名必填'
                            },
                            stringLength: {
                                min: 2,
                                max: 5
                            },
                            remote: { //远程验证
                                type: 'POST',
                                url: '/employee/checkName.do',
                                message: '用户名已被注册',
                                delay: 1000,
                                data: function() {  //自定义提交参数，默认只会提交当前用户名input的参数
                                    return {
                                        id: $('[name="id"]').val(),
                                        name: $('[name="name"]').val()
                                    };
                                }
                            },
                        }
                    },
                </#if>
                /*    email: {
                        validators: {
                            notEmpty: {},
                            emailAddress: {}
                        }
                    },
                    password:{
                        validators: {
                            notEmpty: {}
                        }
                    },
                    repassword:{
                        validators: {
                            notEmpty: {},
                            identical: {
                                field: 'password'
                            }
                        }
                    },
                    age:{
                        validators:{
                            between: { //数字的范围
                                min: 18,
                                max: 60
                            }
                        }
                    }*/
                }
            }).on('success.form.bv', function(e) { //表单验证成功后执行的代码
                //提交异步表单
                $("#editForm").ajaxSubmit(function(data){
                    if(data.success){
                        window.location.href = "/employee/list.do";
                    }else{
                        $.messager.popup(data.msg)
                    }
                })

            });

        })
    </script>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>

    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" >
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name"
                                   <#if employee??>
                                      readonly
                                   </#if>
                                   value="${(employee.name)!}" placeholder="请输入用户名">
                        </div>
                    </div>
                    <#if !employee?? >
                     <#--没有employee对象，就是新增，需要显示密码区域-->
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"  placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword"  name="repassword" placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                <#list departments as d>
                                    <option value="${d.id}">${d.name}</option>
                                </#list>
                            </select>
                            <script>
                                // jquery 回显下拉框 跟 回显input一样，使用val方法就可以
                                $("#dept").val(${(employee.dept.id)!});
                            </script>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                                <#--<#if (employee.admin)!false>-->
                                <#if employee?? && employee.admin>
                                    <script>
                                        $("#admin").prop("checked", true);
                                        $(function () { //页面加载完毕执行
                                            roleDiv = $("#role").detach(); //删除角色div
                                        })
                                    </script>
                                </#if>
                        </div>
                    </div>
                    <script>
                        var roleDiv;
                        // 1.超管的复选框添加点击事件
                        $("#admin").click(function(){
                            // 2.在事件中判断是否有勾选checked
                            var checked = $(this).prop('checked');
                            // 3.如果有选中，删掉角色相关的标签
                            if(checked){
                                roleDiv = $("#role").detach();//保留原本的事件
                            }else{
                                // 4.如果没有选中，恢复角色相关的标签
                                $("#adminDiv").after(roleDiv);
                            }
                        })
                    </script>

                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                     <#list roles as r>
                                         <option value="${r.id}">${r.name}</option>
                                     </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <#--下拉框提交的时候，只会提交选中的数据selected-->
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                       <#list (employee.roles)! as r>
                                            <option value="${r.id}">${r.name}</option>
                                       </#list>
                                </select>
                            </div>
                            <script>
                                // 回显时的角色去重
                                // 1.获取右边以及拥有的角色dom对象数组，遍历去获取到每个option的value
                                // 存放到新的数组中  ids=[1,2,3,4,5]
                                var ids = []; //只要存在改数组中的id，代表当前员工已经拥有的角色id
                                $(".selfRoles > option").each(function(i,ele){
                                    ids.push($(ele).val());
                                })
                                // 2. 遍历左边的每一个option，获取value，判断是否存在ids中，如果存在就删除自己
                                $(".allRoles > option").each(function(i,ele){
                                    var id = $(ele).val();
                                    if($.inArray(id,ids)>-1){
                                        $(ele).remove();
                                    }
                                })

                            </script>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="button" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>

                    <script>
                        $("#submitBtn").click(function () {
                            // 让selfRoles的下拉框，里面的所有option都选中selected
                            $(".selfRoles > option").prop('selected',true);
                            // 提交表单 调用submit方法后，验证插件就会进行验证
                            $("#editForm").submit();
                        })
                    </script>

                </form>
            </div>
        </section>
    </div>
    <#include "../common/footer.ftl">
</div>
</body>
</html>
